## PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2002-208945

(43)Date of publication of application: 26.07.2002

(51)Int.Cl.

H04L 12/56

(21)Application number: 2001-003000

(71)Applicant: FUJITSU LTD

(22)Date of filing:

10.01.2001

(72)Inventor: EZAKI YUTAKA

KAWASAKI TAKESHI

## (54) DESTINATION INFORMATION MANAGING APPARATUS FOR PACKET

## (57)Abstract:

PROBLEM TO BE SOLVED: To provide a destination information managing apparatus for packet capable of keeping more prefixes than those of a CAM, and retrieving prefixes more rapidly than a RAM.

SOLUTION: The apparatus for managing the destination information of the packets for selecting the paths of the packets is provided with a first memory, a second memory having a retrieval speed lower than the first memory and the degree of integration higher than the first memory, and a compiling section for compiling a path table storing the destination information so that the information is over the first and second memories.



国明宗副首部告行

首的山下之酣 計12件

(19)日本国特許庁(JP)

# (12)公開特許公報(A)

(11)特許出願公開番号 特開2002-208945

(P2002-208945A) (43)公開日 平成14年7月26日(2002.7.26)

(51) Int. Cl. 7

識別記号

FΙ

ナーマコート. (参考)

H04L 12/56

100

HO4L 12/56

100

Z 5K030

審査請求 未請求 請求項の数5 〇L (全18頁)

(21)出願番号

特願2001-3000(P2001-3000)

(22)出願日

平成13年1月10日(2001.1.10)

(71)出願人 000005223

富士通株式会社

神奈川県川崎市中原区上小田中4丁目1番

1号

(72)発明者 江▲崎▼ 裕

神奈川県川崎市中原区上小田中4丁目1番

1号 富士通株式会社内

(72)発明者 川崎 健

神奈川県川崎市中原区上小田中4丁目1番

1号 富士通株式会社内

(74)代理人 100089244

弁理士 遠山 勉 (外1名)

最終頁に続く

## (54) 【発明の名称】パケットの宛先情報管理装置

#### (57) 【要約】

【課題】CAMよりも多くのプレフィクスを保持するこ とができ、且つRAMよりも高速にプレフィクスを検索 することが可能なパケットの宛先情報管理装置を提供す る。

【解決手段】パケットの経路を選択するためのパケット の宛先情報を管理する装置であって、第1メモリと、こ の第1メモリよりも情報の検索速度が遅く且つ集積度が 高い第2メモリと、前記宛先情報が前記第1メモリと前 記第2メモリとに跨がる状態で格納された経路表を作成 する作成部とを備える。



### 【特許請求の範囲】

【請求項1】パケットの経路を選択するためのパケット の宛先情報を管理する装置であって、

1

第1メモリと、

前記第1のメモリより情報の検索速度が遅く且つ集積度 が高い第2メモリと、

前記宛先情報が前記第1メモリと前記第2メモリとに跨 がる状態で格納された経路表を作成する作成部と、を備 えたパケットの宛先情報管理装置。

【請求項2】前記第1メモリの使用率の閾値を記憶した 10 閾値記憶部をさらに備え、

前記作成部は、前記第1メモリの使用率を取得し、取得 した使用率が前記閾値記憶部に記憶された閾値未満であ る場合には、前記経路表に格納すべき宛先情報を前記第 1メモリのみに格納する請求項1記載のパケットの宛先 情報管理装置。

【請求項3】前記経路表に格納された宛先情報に対応する出力ルートの情報を得る場合の最大許容時間を記憶した許容時間記憶部をさらに備え、

前記作成部は、前記最大許容時間内で前記経路表から前 20 記パケットの宛先情報が検索され、検索された宛先情報 に対応する出力ルートの情報が取得されるように、前記 宛先情報を前記第1メモリと前記第2メモリとに跨がる 状態で格納する請求項1又は2記載のパケットの宛先情報管理装置。

【請求項4】前記最大許容時間内で可能な前記第2メモリへの最大アクセス回数を記憶したアクセス回数記憶部をさらに備え、

前記作成部は、前記経路表に格納された宛先情報の検索 に必要な前記第2メモリへのアクセス回数が前記最大ア クセス回数以上となる場合には、前記アクセス回数が前 記最大アクセス回数未満となるように、前記第2メモリ に格納された、又は格納される予定の宛先情報を前記第 1メモリに格納する請求項3記載のパケットの宛先情報 管理装置。

【請求項5】パケットの宛先情報が第1メモリとこの第 1のメモリよりも情報の検索速度が遅く且つ集積度が高 い第2メモリとに跨る状態で格納された経路表と、

入力されたパケットに対応する宛先情報を前記経路表から検索し、検索した宛先情報に対応する出力ルートの情 40報を取得する検索部と、を備えたパケットの経路選択装

## 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明はパケットの宛先情報管理装置に関し、例えば、インターネットやイントラネットで利用されるインターネットプロトコル(IP)アドレスを管理する装置に関する。

[0002]

【従来の技術】インターネットやイントラネットは、T 50

CP/IPを利用した通信方式であり、コンピュータ間の簡易な通信方式としてローカル・エリア・ネットワーク(LAN)からワイド・エリア・ネットワーク(WAN)まで広く利用されている。IPでは、あらゆる情報がパケットに区切られて転送される。パケットは、数十パイト〜数十キロバイト程度の可変長のサイズを持つ。パケットには、送信先アドレス(ディスティネーションアドレス)、送信元アドレス(ソースアドレス)等を含むヘッダが添付される。

【0003】インターネットは、一般に、ルータと呼ばれる通信装置を相互接続することによって構築される。ルータは、パケットの宛先情報に基づいて、パケットの経路を選択する(ルーティング:フォワーディングともいう)。即ち、ルータは、パケットを受信すると、受信したパケットのヘッダに格納された宛先IPアドレスに対応する次ホップアドレス(パケットを次に受信すべきルータのIPアドレス)をルーティングテーブル(「フォワーディングテーブル」ともいう)から取得する。ルータは、次ホップアドレスを取得すると、当該次ホップアドレスを持つルータへパケットを転送する。ルーティングテーブルは、パケットの宛先のネットワーク(「ドメイン」と呼ばれる)のIPアドレス(「プレフィクス」と呼ばれる)と、プレフィクスに対応する次ホップアドレスとを記憶している。

【0004】ダイナミックルーティングが採用される場合、ルータは、ルーティングプロトコルに従って、ルーティング情報(プレフィクス等)を他のルータと相互に交換し、ルーティングテーブルを作成する。ルーティングテーブルは、上記したルーティング情報の交換が定期的,周期的に実行されることによって、数分~数時間毎に更新される。ルーティングプロトコルには、例えば、OSPF(Open ShortestPath First), RIP(Routing Information Protocol), BGP(Border Gateway Protocol)等がある。

[0005]ルーティングは、ルータに到着したパケット毎に実行される。このため、ルーティング性能は、ルータの性能を決定する大きな要因となっている。インターネットサービスプロバイダ(ISP)によって使用されるルータでは、約25万のIPアドレスに対応する次ホップアドレスを検索可能なルーティングテーブルが要求される。このような大容量の情報を高速に検索可能であり、且つ効率的に保存する技術が従来から検討されてきた。

【0006】ルーティングテーブルの構成方法には、大略して、CAM(Contents Accessable Memory:「連想メモリ」と呼ばれる)などの専用のメモリを利用する方法(「CAM方式」という)と、RAM(Rundam Access Memory)を用いてツリーを構成する方法(「RAMツリー方式」という)とがある。

【0007】 I Pアドレスは、ネットワークアドレス

(プレフィクス)とホストアドレスとで構成される。有効 なプレフィクス長(有効長)は、ネットワーク構成やアド レス情報の集約(アグリゲーション)によって変化する。 具体的に説明すると、一般に、ネットワークは、コア (中継)、エッジ等からなる階層で構成されており、ルー タが保持すべき機能やルーティング情報の細かさ(アド レスのアグリゲーションの細かさ)は、ルータ毎に異な る。例えば、ネットワークが、図12に示すように構成 されている場合、LANでは、ルーティングの際に、I Pアドレスの全アドレス長(32ピット)がプレフィクス 10 (/32)として使用される。これに対し、アクセスネッ トワークでは、ルーティングに際し、IPアドレスの上 位24ビット(/24)がプレフィクスとして使用され る。さらに、コアネットワークでは、ルーティングに際 し、IPアドレスの上位16ピット(/16)がプレフィ クスとして使用される。

【0008】このように、ネットワークの中心部に進むに従ってルーティングに使用されるプレフィクスが短くなる。これに従い、LANとアクセスネットワークとを結ぶルータ(エッジルータ)は、IPアドレスの全パイト 20 又は上位24パイトを利用してルーティングを行う。また、アクセスネットワークとコアネットワークとを結ぶルータ(コアルータ)は、IPアドレスの上位24パイト又は上位16パイトを利用してルーティングを行う。

【0009】但し、実際には、CIDR(Classless Inter-Domain Routing)によって、個々のルータが受け取ったルーティング情報に基づく経路集約の計算が行われる。このため、プレフィクス長は固定ではなく、ドメインのIPアドレス毎に異なるプレフィクス長が用いられる。なお、CIDRのネットワークアドレスは、IPア 30ドレス(プレフィクスに相当)とマスク値とで表現される。マスクは、ネットワークアドレスの有効ビットであり、アドレスの最左端(最上位ビット)からの可変の連続ビット列で表現される。

【0010】ところで、ルータに入力されるパケットには、有効長が明示されていない。このため、ルータは、パケットの宛先のIPアドレスに対応するプレフィクスを検索する場合には、ロンゲストマッチ(longest match)検索と呼ばれる特別な検索手順を実施する。ロンゲストマッチ検索は、宛先のIPアドレスのうち、プレフィ40クスを構成するビット列について、最左端(最上位)からのビット列が最長に一致するプレフィクスのエントリをルーティングテーブルから検索する方法である。

【0011】 CAMは、エントリとして記憶されている 内容をキーとして、キーに対応するエントリのアドレス を出力する特殊なメモリである。CAM方式を用いれ ば、宛先のIPアドレスに対応するプレフィクスを、R AMツリー方式に比べて高速に検索することができる。 【0012】 RAMツリー方式では、RAM上にプレフ ィクスのエントリがツリー状に並べられ、宛先IPアド 50 レスの各ビットが最上位ビットから最下位ビットへ向かってビット毎に比較されることによって、対応するプレフィクスのエントリが検索される。図13は、RAMツリー方式による検索方法の説明図である。図13には、ツリー構成方法の1つとしてのパトリシア(PATRICIA)ツリーの論理構成が示されている。

【0013】パトリシアツリーでは、エントリデータとして、プレフィクス値、マスク値(有効長)、0ポインタ(ゼロポインタ)、1ポインタ(ワンポインタ)、及びルーティング情報(次ホップアドレス)が、RAM上に設定される(図14参照)。バトリシアツリーは、エントリデータに応じて設けられた複数のノードN及びリンクしからなる。各ノードNは、上記したプレフィクス値と有効長とを有し、さらに、ノードNでの処理対象となるピット(0又は1)に対応するポインタP1及びポインタP2を有している。ポインタP1又はポインタP2のジャンプ先に相当するノードNがある場合には、ノードN同士はリンクしで接続される。

[0014] 図13には、"000xxxxx(0/3)","001xxx xx(32/3)","010xxxxx(64/3)","011000xx(96/6)", "01100011(99/8)","011001xx(100/6)","01101xxx(104/5)","0111xxxx(112/4)","100xxxxx(128/3)","101xxxxx(160/3)","110xxxxx(192/3)",及び"111x xxxx(224/3)"の各エントリデータに応じたパトリシアツリーが示されている。ここでは、例として、プレフィクスの最大有効長が、8ビットで設定されている。

[0015] エントリデータ中の"x"は、プレフィクス中の無効ビットを示す。括弧中の左側の数字は、プレフィクス値を示し、エントリデータ中の"x"に"0"を代入した場合における2進数の値を10進数に換算した値である。また、右側の数字は、有効長を示す。例えば、エントリデータ"001xxxxx"は、プレフィクス"32"を示し、有効長は3ビットである。

【0016】パケットの宛先IPアドレスのプレフィク スが、図13に示すように"01100010(98)"である場合 には、最初のノードN(図13の最も左側のノードN)に おいて、最左端のビット(最上位ビット)が0か1かが判 定される。このとき、ビットは"0"であるので、ポイ ンタP1に従った次のノード(プレフィクス値が"0" で有効長が1のノードN((0/1)のノードN))へ進 み、次のピットが0か1かが判定される。このような処 理がポインタP1又はP2で指定されるリンク先が無く なるまで繰り返し行われる(図13における太線の矢印 参照)。その後、リンク先が或るノードNで無くなった 時に、宛先のIPアドレスに対応するプレフィクス(宛 先のネットワークアドレス)が特定される。そして、特 定されたプレフィクスに対応する次ホップアドレスが出 カルートの情報としてルーティングテーブルから取り出 される。

【0017】実際のRAM上では、パトリシアツリー

は、図14に示すようなツリーテーブルに格納される。例えば、図14に示すツリーテーブルを用い、 "010" というプレフィクスを検索する場合には、以下の処理が行われる。即ち、最初のエントリでは、最上位ビット "0"に基づいて0ポインタが翻べられ、0ポインタで示されたエントリにジャンプする(S101)。次のエントリでは、次のビット "1"に基づいて1ポインタが調べられ、1ポインタで示された次のエントリにジャンプする(S102)。そして、次のエントリでは、最下位ビット "0"に基づいて0ポインタが調べられる。このピット "0"に基づいて0ポインタが調べられる。このとき、0ポインタには、ジャンプ先が無いことを示すエンドフラグがジャンプ先のアドレスの代わりに格納されている。このため、当該エントリに格納されている出力ルートの情報(次ホップアドレス)がツリーテーブルから読み出される(S103)。

#### [0018]

【発明が解決しようとする課題】RAMツリー方式では、プロセッサ(CPU, MPU等)が、ソフトウェアの実行によって、プレフィクスを構成するビット毎にRAM上のツリーテーブルを次々と読み込んでいく。このた20め、プロセッサの読み込み回数(メモリアクセスの回数)が有効長に比例する。IPアドレス(最長32ビット)の場合、有効長の平均値は20ビット程度である。このため、20回程度のメモリアクセスが必要になる。このため、20回程度のメモリアクセスが必要になる。このことに鑑み、例えば、1回のRAMアクセスを30ナノ秒[ns]程度で実行可能なRAMを使用しても、検索が終了するまでに平均600[ns]、遅い場合には1マイクロ秒[μs]程度かかる。従って、RAMツリー方式では、パケットの転送性能を1Mpps[mega packet persecond]程度までしか上げることができなかった。30

【0019】RAMは集積度が高く、パトリシアツリーは、比較的効率的にプレフィクスのエントリを格納することができる。このため、RAMツリー方式がISPのルータに採用された場合でも、ルーティングテーブルには必要なエントリを格納することができる。半導体技術の発達により、プロセッサがツリーテーブルからルーティング情報を検索する手順をハードウェア化した装置("レイヤ3スイッチ"と呼ばれる)もある。

【0020】しかしながら、ツリー方式は、CAM方式に比べて検索速度が遅いという問題があった。具体的に 40は、CAM方式が、数十メガppsでパケットを転送可能であるのに対し、RAMツリー方式では約1メガppsである。但し、CAMの集積度は、RAMに比べて低く、現状では、数キロエントリ程度しか実現されていない。

【0021】上述したように、ルーティングテーブルに 格納すべきエントリ数は、インターネットの拡大に伴っ て増加している。また、パケットの転送速度の向上も望 まれている。このため、数百キロエントリという大容量 で且つ数十メガppsという高速に検索可能なルーティ 50 ングテーブルを実現することが望まれている。

【0022】本発明の目的は、CAM方式で作成された ルーティングテーブルよりも多くのプレフィクスを保持 することができ、且つRAMツリー方式で作成されたル ーティングテーブルよりも高速にプレフィクスを検索す ることが可能なパケットの宛先情報管理装置を提供する ことである。

#### [0023]

【課題を解決するための手段】本発明は、上述した目的 を達成するために以下の構成を採用する。

【0024】即ち、本発明は、パケットの経路を選択するためのパケットの宛先情報を管理する装置であって、第1メモリと、前記第1メモリよりも情報の検索速度が遅く且つ集積度が高い第2メモリと、前記宛先情報が前記第1メモリと前記第2メモリとに跨がる状態で格納された経路表を作成する作成部と、を備える。

【0025】本発明によると、第2メモリよりも検索速度が速い第1メモリに宛先情報の一部が格納されるので、第2メモリのみを用いて格納された宛先情報を検索する場合よりも速く宛先情報を検索することができる。また、第2メモリは、第1メモリよりも集積度が高いので、第1メモリのみを用いる場合よりも多くの宛先情報を格納することができる。

【0026】第1メモリは、例えばCAM(連想メモリ)であり、第2メモリは、例えばRAMである。宛先情報は、例えばパケットの宛先のIPネットワークアドレス(プレフィクス)や、VPN識別子とIPネットワークアドレスとの組み合わせである。

【0027】本発明は、前記第1メモリの使用率の閾値 30 を記憶した閾値記憶部をさらに備え、前記作成部は、前 記第1メモリの使用率を取得し、取得した使用率が前記 閾値記憶部に記憶された閾値未満である場合には、前記 経路表に格納すべき宛先情報を前記第1メモリのみに格 納する、構成とするのが好ましい。

【0028】また、本発明は、パケットの宛先情報が第 1メモリとこの第1のメモリよりも情報の検索速度が遅 く且つ集積度が高い第2メモリとに跨る状態で格納され た経路表と、入力されたパケットに対応する宛先情報を 前記経路表から検索し、検索した宛先情報に対応する出 カルートの情報を取得する検索部と、を備えた経路選択 装置である。

#### [0029]

【発明の実施の形態】以下、図面を参照して本発明の実施形態を説明する。なお、本発明は、実施形態の構成に限定されるものではない。

#### 【0030】 [第1実施形態]

(ルータの構成) 図1は、本発明による宛先情報管理装置及び経路選択装置が適用された通信装置としてのルータ1の構成例を示す図である。ルータ1は、大きく分けて、物理層(レイヤ1)及びデータリンク層(レイヤ2)に

関する処理を実行する複数のインターフェイスカード2と、パケットのルーティング(ネットワーク層:レイヤ3)に関する処理を行うルーティング機構3とを備えている。インターフェイスカード2は、パケットの出カルート(入力ルート)毎に設けられている。

【0031】ルーティング機構3は、ルーティングプロトコル処理部4と、ルート計算・経路表作成部5(以下、「経路表作成部5」と表記)と、ルーティングテーブル(経路表)20と、ヘッダ抽出部8と、アドレス検索部9と、転送処理部10とを備えている。なお、ルーテ 10ィング機構3が、本発明の管理装置及び経路選択装置に相当し、経路表作成部5が本発明の作成部に相当し、アドレス検索部9が本発明の検索部に相当する。

【0032】ルーティングプロトコル処理部4は、RIP,OSPF、BGP等の所定のルーティングプロトコルに従ってルーティング情報の交換処理を実行し、他のルータからルーティング情報(プレフィクス等)を取得し、取得したプレフィクスを経路表作成部5に与える。

【0033】経路表作成部5は、ルーティングプロトコル処理部4から受け取ったプレフィクスに対応する最適 20な出力ルートを計算し、プレフィクスと算出された出力ルートの情報(次ホップアドレス)とが格納されたルーティングテーブル20を作成する(本発明の閾値記憶部,許容時間記憶部,アクセス回数記憶部に相当)。

【0034】ルーティングテーブル20は、第1メモリとしてのCAM6と、第2メモリとしてのRAM7とを含んでいる。CAM6及びRAM7は、経路表作成部5によって格納されたプレフィクス及び次ホップアドレスに関するエントリを保持する。 なお、本実施形態では、ダイナミックルーティングによってプレフィクスが 30取得される例について述べているが、本発明は、スタティックルーティングによって作成されたルーティングテーブルを持つルータにも適用可能である。

【0035】ヘッダ抽出部8は、各インターフェイスカード2からルーティング機構3に入力されたパケットのヘッダを抽出し、抽出したヘッダから宛先IPアドレス(ディスティネーションIPアドレス)を取り出し、アドレス検索部9に与える。

【0036】アドレス検索部9は、ヘッダ抽出部8から受け取った宛先IPアドレスのプレフィクスに対応する 40 次ホップアドレスをルーティングテーブル20から読み出し、転送処理部10に与える。

【0037】転送処理部10は、ルーティング機構3に入力されたパケットをアドレス検索部9から受け取った次ホップアドレスに対応するインターフェイスカード2に入力する。

【0038】インターフェイスカード2は、ルーティング機構3から入力されたパケットに対し、レイヤ1及びレイヤ2に関する処理(例えば、宛先MACアドレスの書換)を行う。その後、インターフェイスカード2は、

パケットを次ホップアドレスに相当する他のルータへ転送する。

【0039】なお、ルーティングプロトコル処理部4,経路表作成部5,ヘッダ抽出部8,アドレス検索部9は、CPU等のプロセッサ(図示せず)がプログラムを実行することによって実現される機能である。転送処理部9は、例えば、ソフトウェア又はハードウェアで実現されるスイッチを用いて構成される。

【0040】〈CAMの構成〉次に、CAM6について説明する。CAMは、与えられたパターンにマッチするエントリのアドレスを出力する特殊なメモリである。比較パターンとして"0"又は"1"しか設定できないCAMは、"bimary CAM"と呼ばれ、比較パターンとして"0","1"及び"d.c.(マスク)"の3パターンを設定可能なCAMは、"ternary CAM"と呼ばれる。

【0041】図2は、CAM6の構成例を示す図である。CAM6は、ピット毎に比較器を有する特殊な記憶素子を複数アレイ上に並べて構成されたデータアレイ及びマスクアレイ12と、ロンゲストマッチ検索やアドレスの優先制御を実行するプライオリティ・エンコーダ(priority encoder)13と、書込データ等を出入力するための入出力制御装置(I/O:図示せず)とを備えており、CAM6の出力信号は、補助RAM14に入力される。

【0042】ロンゲストマッチ検索の前提として、書込データとしてのプレフィクスとマスク情報との組み合わせが、I/Oを通じてデータアレイ/マスクアレイ12にエントリとして書き込まれる。比較対象(出力ルートの検索対象)としての宛先IPアドレスがI/Oを通じてCAM6に入力されると、当該宛先IPアドレスとデータアレイ/マスクアレイ12の各エントリとが比較され、比較対象の宛先IPアドレスに一致するプレフィクスを保持したエントリのアドレス(CAMアドレス)が検出される。

【0043】プライオリティ・エンコーダ13は、複数のCAMアドレスが検出された場合に、宛先IPアドレスに最長に一致する(有効長が最も長い)CAMアドレス,或いは、優先すべきCAMアドレスを特定し、特定されたCAMアドレスが出力される。

【0044】ternary CAMとしてのCAM6によるプレフィクス検索の例を図2を用いて説明する。今、CAM6のデータアレイ/マスクアレイ12には、図2に示すように、複数のプレフィクスとマスク情報との組み合わせがエントリとして書き込まれている。この例では、エントリに保持されたプレフィクスは、有効長が長い順でソートされている。

【0045】 ここで、例えば、或るパケットの宛先IP アドレス"192.168.0.177" がCAM11 に入力されたとする。すると、宛先IPアドレス"19 2.168.0.177" と、データアレイ/マスクア レイ12に保持されたエントリ(プレフィクスとマスク情報との組み合わせ)の夫々とが比較され、両者が合致するCAMアドレスを示す信号が、プライオリティ・エンコーダ13に入力される。図2に示す例では、CAMアドレス"1", "1003", "1007"及び"65535"が、プライオリティ・エンコーダ13に入力される。

【0047】補助RAM14は、CAMアドレスに対応する次ホップアドレスを保持しており、CAMアドレス"1"が入力されると、入力されたCAMアドレスに対応する次ホップアドレスを出力する。出力された次ホップアドレスは、アドレス検索部9に与えられる。その後、次ホップアドレスは、転送処理部10に与えられ、転送処理部10は、パケットを次ホップアドレスに対応するインターフェイスカード2は、受け取ったパケットを次ホップへ転送する。

【0048】 CAM 6 は、宛先 I Pアドレスが CAM 1 1に入力されてから CAMアドレスを示す信号が補助 RAM 14 に格納されるまでの動作(宛先 I Pアドレスに対するロンゲストマッチ検索)を一度に行うことができる。現状では、CAMは、5 千万~1 億サーチ/秒(=10 ~ 20 ns/サーチ)の速度で高速な検索を行うことができる。但し、CAM 6 の集積度は、前述した比較機能を有するために、数M b i t であり、RAMに比べて数分の1 に落ちる。

【0.049】 (RAMの構成) RAM7には、図13に示したようなパトリシアツリー(ツリーテーブル)が作成される。即ち、RAM7は、プレフィクス、マスク長、0ポインタ、1ポインタ、及び次ホップアドレスをエントリとして格納したツリーテーブルを格納している(図14参照)。RAMツリー及びツリーテーブルの構造自体は、図13及び図14に示したものと同じである。経40路表作成部5は、新規のプレフィクスと、このプレフィクスに対応する次ホップアドレスを含むエントリをパトリシアツリー(ツリーテーブル)に追加する。この場合には、経路表作成部5は、図3に示す4つのパターンの何れかに従ってエントリを追加する。4つのパターンは、以下の通りである。

(A)第1パターン: 既存ノードに一致する場合

(B)第2パターン: 既存ノードに子ノードとして追加する場合

(C)第3パターン:既存ノードの中間に追加する場合

(D)第4パターン:既存ノードから分木ノードとともに 追加する場合

第1パターンでは、エントリは、ツリー上に既に存在するノード(図3(A)のノードN1)に追加される。第2パターンでは、エントリは、ツリー上に既に存在するノード(図3(B)のノードN3)として追加される。第3パターンでは、エントリは、或る親ノード(図3(C)のノードN4)と子ノード(図3(C)のノードN5)との間の中間ノード(図3(C)のノードN6)として追加される。

【0050】第4パターンでは、エントリは、或る親ノード(図3(D)のノードN7)と子ノード(図3(D)のノードN9)とともに、分木ノードの子ノード(図3(D)のノードN9)とともに、分木ノードの子ノード(図3(D)のノードN-10)として追加される。エントリが追加された場合、経路表作成部5は、追加されたエントリ(ノード)に関連するノードのポインタ(0ポインタ及び/又は1ポインタ)を正しく付け替える。これによって、RAMツリーが修正される。

【0051】 (経路表を用いたアドレス検索) 次に、アドレス検索部9がルーティングテーブル20を用いて次ホップアドレスを検索する処理について説明する。図4は、実施形態におけるルーティングテーブル20の構成図である。図4において、CAM6は、ternary CAMを用いて構成されている。RAM7は、パトリシアツリー(RAMツリー)17(のツリーテーブル)を格納している。

【0052】本実施形態では、宛先IPアドレスに対応するプレフィクスは、以下の3つのパターンの何れかによってルーティングテーブル20に格納されている。

- (A) CAM 6 のエントリとして格納
- (B) RAMツリー17のエントリとして格納
- (C) C A M 6 及び R A M ツリー 1 7 に亘って(跨って)格 ぬ

上記したパターン(C)では、プレフィクスが所定数の有効ビットからなることに鑑み、プレフィクスのうち、最左端のビット(最上位ビット)から所定ビットまで(第1の部分)を検索するためのエントリがCAM16にセットされ、上記所定ビットから最後のビット(最下位ビット)まで(第2の部分)を検索する為のエントリが、RAMツリー17にセットされる。

【0053】例えば、プレフィクス"0000xxxx"(プレフィクス値0/有効長4)を、パターン(C)でルーティングテーブル20にセットする場合には、CAM6及びRAMツリー17は、以下の構成を持つ。即ち、CAM6のデータアレイ/マスクアレイ12には、"0(0xxxx xxx)/1"のエントリE1が設けられる。一方、RAMツリー17には、"0/1"のエントリを保持したノードN11が設けられる。

0 【0054】エントリE1のアドレス(CAMアドレス)

は、ノードN11のRAMアドレスにリンクされている。これによって、アドレス検索部9(図1参照)は、CAM16から出力されるエントリE1のアドレスを用いてノードN11にアクセスすることができる。

【0055】即ち、パターン(C)でプレフィクスがセットされる場合には、CAMアドレスに対応するRAMアドレス(RAMツリーのエントリ(ノード)のアドレス)が、CAMアドレスに対応する次ホップアドレスの代わりに、補助RAM14(図2参照)に格納される。ノードN11は、"0/2"のエントリを保持したノードN12に0ポインタを介してリンクされており、ノードN13に0ポインタを介してリンクされている。

【0056】また、例えば、プレフィクス"0110000x" (プレフィクス値96/有効長7)について、CAM6及びRAMツリー17は以下の構成を持つ。即ち、CAM6のデータアレイ/マスクアレイ12には、"96(01100xxx)/5"のエントリE2が設けられている。一方、RAMツリー17には、"96/5"のエントリを保持したノードN21が設けられている。

【0057】エントリE2のCAMアドレスは、ノード N21のRAMアドレスと補助RAM14を介してリンクされており、アドレス検索部9は、CAM16から出力されるエントリE2のCAMアドレスを用いてノード N21にアクセスすることができる。ノードN21は、"96/6"のエントリを保持したノードN22に0ポインタを介してリンクされている。

【0058】アドレス検索部9は、ヘッダ抽出部8から 宛先IPアドレスを受け取ると、以下のルーティング処理を実行する。即ち、アドレス検索部9は、宛先IPアドレスをCAM6に入力する。ここで、入力された宛先IPアドレスが、例えば"01100000"である場合には、CAM6は、ロンゲストマッチ検索によって、プレフィクスの最上位ビットからの各ビット値が最長に一致する"96/5"のエントリE2のCAMアドレスを出力する。出力されたCAMアドレスは、補助RAM14に入力される。すると、エントリE2のCAMアドレスに対応するRAMアドレス(ノードN21のアドレス)が補助RAM14からアドレス検索部9に与えられる。

【0059】アドレス検索部9は、補助RAM14からRAMアドレスを受け取ると、受け取ったRAMアドレスを用いてRAMツリー17のノードN21にアクセスする。次に、アドレス検索部9は、ノードN21の0ポインタによって指定されたノードN22にアクセスする。

【0060】アドレス検索部9は、ノードN22にて0ポインタを参照する。0ポインタは、指定されるリンク先の代わりに、リンク先がないことを示すエンドフラグを格納している。そこで、アドレス検索部9は、宛先IPアドレスに対応するプレフィクスが"011000xx(96

/6)"であるものとして、プレフィクス"96/6"に対応する次ホップアドレスをRAM7から読み出す。このようにして、宛先IPアドレスに対応するプレフィクスが特定され、出力ルート(次ホップ)が決定される。 [0061] 上述したルーティング処理によると、宛先IPアドレスに対応するプレフィクスのうち、最上位ビットから5ビット目までが、CAM16によって一度に検索される。その後、プレフィクスの6ビット目と7ビット目についての処理が、RAMツリー17を用いて行われ、宛先IPアドレスのプレフィクスが特定される。 [0062] 上記ルーティング処理において、最上位ビットから5ビット目までに対する処理は、RAMツリー17のみを用いて行うと、5回のRAMアクセスを要する。これに対し、上記ルーティング処理は、CAM16を用いて一度に行うため、検索時間が短縮される。

【0063】また、7ビットの有効長を持つプレフィクスがRAMツリー17のみを用いて検索される場合には、7回のRAMアクセスが必要である。これに対し、上記ルーティング処理は、RAMアクセスを2回に抑えることができる。従って、検索に必要な時間が、RAMツリー17のみを用いてプレフィクスを検索する場合に比べて短縮される。一方、プレフィクスのエントリが、上記したパターン(B)によってRAMツリー17に設定される。このため、CAM6に設定されるエントリの数を減らすことができる。

【0064】従って、上述したルーティングテーブル20によれば、ルーティングテーブルがCAMのみを用いて構成される場合よりも多くのエントリを格納することができる。一方、ルーティングテーブル20によれば、1つのパケットについてルーティングに要する時間を、ルーティングテーブルがRAMツリーのみを用いて構成される場合よりも短縮することができ、ルーティング性能の向上を図ることができる。

【0065】 (エントリの追加) ネットワークのトポロジは、ネットワークの再構築,ネットワークの保守・点検,リンクやノードの障害等によって変化する。トポロジが変化すると、ルータ1から或るネットワークへ至る最適なルートが変化する。ルータ1は、トポロジの変化に対応すべく、定期的又は周期的にルーティングテーブル20を更新する。 即ち、ルータ1のルーティングプロトコル処理部4は、定期的又は周期的にルーティングプロトコルに従ってルーティング情報の交換を行い、他のルータから取得したルーティング情報からプレフィクスを抽出し、経路表作成部5に与える。 経路表作成部5は、新たなプレフィクスをルーティングプロトコル処理部4から受け取った場合には、受け取ったプレフィクスペパケットを転送するための最適な出力ルートを計算し、計算結果に基づいて次ホップを決定する。

【0066】そして、経路表作成部5は、受け取ったプ 50 レフィクスをルーティングテーブル20にエントリとし

て格納し、格納された新たなエントリと決定された次ホップアドレスとを関連づける。これによって、アドレス検索部9が、新たなエントリに対応する宛先 I Pアドレスを持つパケットについて、対応する次ホップアドレスを得ることができる。

【0067】図5及び図6は、経路表作成部5によるエントリの追加処理を示すフローチャートである。図5において、ルータ1の管理者は、CAM6の利用率の閾値 $\eta c(max)$ と、RAM7の利用率の閾値 $\eta r(max)$ とを、経路表作成部5の図示せぬメモリに格納する(ステップS1)。

【0068】 CAM 6の利用率 $\eta$ cは、CAM 6(のデータアレイ/マスクアレイ 12) に格納されたエントリ数をCAM 6 に格納可能な全エントリ数で除した値(CAM 6 のエントリ利用率)である。一方、RAM 7 の利用率 $\eta$ rは、RAM  $\eta$  にRAMツリー 1 7を構成するノードとして格納されたエントリ数をRAM  $\eta$  に格納可能な全エントリ数で除した値(RAM  $\eta$  のエントリ利用率)である。

【0070】その後、ステップS3以降の処理は、経路表作成部5が、ルーティングプロトコル処理部4からプレフィクスを受け取った場合に開始される。経路表作成部5は、ルーティングプロトコル処理部4から1以上の30プレフィクスを受け取ると(ステップS3; Yes)、ルーティングテーブル20に追加すべき新たなプレフィクスが受け取ったプレフィクスに含まれているか否かを判ったし(ステップS4)、含まれていない場合には処理をステップS3に戻し、含まれている場合には、処理をステップS5に進める。

【0071】ステップS5では、経路表作成部5は、追加対象の新規のプレフィクス(新たに得られたプレフィクス)を"N"に設定し、プレフィクス"N"の有効長を"n"に設定する。続いて、経路表作成部5は、プレ 40フィクス"N"を用いてルーティングテーブル20を検索し、ルーティングテーブル20にエントリとして格納されているプレフィクスのうち、プレフィクス"N"と最長に一致するプレフィクス"M"と、プレフィクス"M"の有効長"m"を求める(ステップS6)。次に、有効長"n"から有効長"m"を減算し、有効長の差分 δを求める(ステップS7)。

【0072】次に、経路表作成部5は、図6に示すように、CAM6の利用率 $\eta$ cを計測するとともに、RAM7の利用率 $\eta$ rを計測する(ステップS8)。次に、経路

表作成部 5 は、CAM 6 に十分な空き領域があるか否かを判定する(ステップS 9)。即ち、経路表作成部 5 は、CAM 6 の利用率 $\eta$ cが条件" $\eta$ c  $< \eta$ c (max)"を満たすか否かを判定する。

【0073】このとき、条件が満たされる場合(ステップS9; Yes)には、経路表作成部5は、プレフィクス"N"のエントリをCAM6に追加(格納)する(ステップS10)。

【0074】 このように、利用率 η c の値が関値 η c (ma 10 x)未満である場合には、CAM 6 の利用率 η c が低く、CAM 6 に十分な空き領域があるものとして、プレフィクス "N" のエントリがCAM 6 のみに格納される。これによって、ルーティング時間を短縮することができる。これに対し、条件が満たされない場合には、処理がステップS11に進む。

【0075】ステップS11では、経路表作成部5は、RAM7に十分な空き領域があるか否かを判定する。即ち、経路表作成部5は、RAM7の利用 $\alpha$  $\eta$ rが条件 " $\eta$ r $< \eta$ r(max)"を満たすか否かを判定する。

【0076】このとき、条件が満たされない場合(ステップS11;No)には、ルータ1は、プレフィクス "N"のエントリをルーティングテーブル20に登録できないものとしてエラーを出力する(ステップS12)。これに対し、条件が満たされる場合(ステップS11;Yes)には、処理がステップS13に進む。

【0077】ステップS13では、経路表作成部5は、差分 $\delta$ に対応するRAMツリーが作成された場合に、作成されたRAMツリーにアクセスする回数(追加ツリーの段数)がRAM7の最大アクセス回数 $\delta$ max未満か否か(許容範囲内か否か)を判定する。

[0078] 即ち、経路表作成部 5 は、差分  $\delta$  が条件 " $\delta$  max  $> \delta$ " を満たすか否かを判定する。このとき、経路表作成部 5 は、差分  $\delta$  が条件を満たす場合(ステップ S 1 3 ; Yes)には、差分  $\delta$  に対応する各ビットのノード(エントリ)をRAM 7 に登録する(ステップ S 1 5)。

【0079】 ここで、ルーティングテーブル20には、 既に、プレフィクス"M"が格納されている。このと き、プレフィクス"M"がCAM6のみに格納されてい る場合には、差分δに対応する各ピットのノードのう ち、最もルート(root)側(上流側)のノードとCAM6に 格納されたプレフィクス"M"のエントリとが、上記手 法によって、リンクで接続される。

【0080】 これに対し、プレフィクス"M"の有効ビットの最下位ビットがRAM7にノードとして格納されている場合には、差分 $\delta$ に対応する各ビットのノードは、当該ノードの後段にリンク付けされて配置される。 【0081】 これらによって、プレフィクス"N"の有効ビットのうち、最上位ビットから所定ビット(第1の

50 部分)までがСАМ6に格納され、所定ビットから最下

位ピットまで(第2の部分)がRAMツリー17に格納さ れる。即ち、プレフィクス"N"が、CAM6をルート (root)とするツリーに格納される。これによって、CA

15

M 6 のオーパーフローが防止される。

【0082】また、プレフィクス"M"に相当するプレ フィクスがルーティングテーブル20に格納されていな い場合には、プレフィクス"N"は、ステップS15に おいて、RAM7のみに格納される。なお、CAM6が "0/0"のエントリを有していれば、ルーティングテ ープル20に格納される全てのプレフィクスは、CAM 10 6とRAMツリー17とに跨って格納される。

【0083】経路表作成部5は、差分δが条件を満たさ ない場合(ステップS13;No)には、CAM6のエン トリの書換処理を行う(ステップS14)。即ち、経路表 作成部5は、CAM6に格納されているCAMエントリ の何れかを削除する。続いて、経路表作成部5は、プレ フィクス "N"をCAM6にエントリとして格納する。 或いは、経路表作成部5は、プレフィクス"N"のう ち、最上位ピットから所定ピットまでをCAM6に格納 し、且つ所定ピットから最下位ピットまでに対応するノ 20 ード(エントリ)をRAM7に格納(追加)する。

【0084】上記処理によると、プレフィクス"N"に 関するRAMツリー17の段数が減少する。従って、ア ドレス検索部9によるRAM7のアクセス回数が減少す る。このため、アドレス検索部9がプレフィクス"N" に対応する次ホップアドレスを宛先IPアドレスに対応 する次ホップアドレスとして取得するために必要な時間 が許容時間Tmaxを超えてしまうことが防止される。

【0085】経路表作成部5は、CAM6からCAMエ ントリを削除する場合には、少なくとも以下の方法の何 30 れかを用いて削除すべきCAMエントリを選択する。

- (1)ランダムでCAMエントリを選択
- (2)有効長が短い順でCAMエントリを選択
- (3)有効長が長い順でCAMエントリを選択。
- (4)リンクされたRAMツリーが短い順でCAMエント リを選択

上記(3)の方法を使用する場合には、経路表作成部5 は、ホストアドレスのエントリである(/32)のCAM エントリを選択することができる。上記(4)の方法を使 用する場合には、CAMエントリとリンクで接続されて 40 いるRAMエントリからのRAMツリー長を比較し、R AMツリー長が短い方のCAMエントリを削除する。

【0086】例えば、図8に示す例では、経路表作成部 5は、プレフィクス"96/3"のRAMエントリのノ ードを起点とするRAMツリーと、プレフィクス"96 / 5"のRAMエントリのノードを起点とするRAMツ リーとを比較し、"96/5"のRAMエントリのノー ドの方がRAMツリーが短いため、当該RAMエントリ に対応する"96/5"のCAMエントリを削除する。

【0087】経路表作成部5は、上記(4)の方法を用い 50

た選択処理を実施するため、RAMエントリ上、又は図 示せぬ作業メモリの対応する場所に、CAMエントリと リンクされたRAMツリーの段数を書き込む。そして、 経路表作成部5は、上記(4)の方法でCAMエントリを 削除する場合に、予め書き込んだ段数を参照し、最も短 いRAMツリーとリンクで接続されたCAMエントリを 選択して削除する。

【0088】図7は、CAM6にエントリを追加するこ とでRAMツリー17の段数を減らす処理例を示す図で ある。図7では、CAM6AのエントリA'(符号25) と、ノード26(エントリA)、ノード27(エントリ B)、ノード28(エントリM)、及びノード29(エント リX)とからなるRAMツリー17Aとによってプレフ ィクス "M" が登録されている。このようなルーティン グテーブル20Aに対し、新規のプレフィクス"N"を 登録する場合を考える。

【0089】この場合において、例えば、以下のように 仮定する。即ち、ノード29(エントリX)の後段にノー ド30(エントリY)を追加すれば、プレフィクス"N" をルーティングテーブル20Aに登録することができ る。しかし、ノード30が追加されると、RAMツリー 17Aの段数(RAMへのアクセス回数)が最大アクセス 回数 δ maxを超えてしまう。

【0090】この場合、経路表作成部5は、プレフィク ス "N" についてのRAMツリー17Aのルート(root) であるノード26(エントリA)と、追加すべきリーフ(1 eaf)のノード30(エントリY)との中間に位置するノー ド32(エントリM)に対応するエントリM'(符号31) をCAM6Aに追加する(ステップS14)。その後、ノ ード30(エントリY)を追加する(ステップS15)。

【0091】このようにすれば、ノード30が追加され ても、プレフィクス"N"に係るRAMツリー17Aの 段数は、ノード30の追加前のほぼ半分になる。これに よって、RAMへのアクセス回数が最大アクセス回数δ max未満に抑えられる。また、RAMへのアクセス回数 が減少するので、プレフィクス"N"の検索時間が短縮 される。

【0092】なお、図7を用いてRAMツリーの段数を ほぼ半分にする例について説明したが、当該例のように ルートのノード26からリーフのノード30までに亘っ て分木がない場合には、ノード29のエントリXやノー ド30のエントリYに対応するエントリをCAM6Aに 格納すれば、RAMへのアクセス回数をさらに減らすこ とができる。

【0093】このように、CAMへのエントリの追加に よってRAMツリーの段数(アクセス回数)を減らす場合 には、他のプレフィクスの検索に影響を与えない範囲 で、可能な限りアクセス回数が減るようなエントリを選 択するのが好ましい。

【0094】図6に戻って、ステップS15の後、経路

多xsm3 淺回大寸个下大量な淺弱、大濱多淺弱の一UV ス "99/8" のRAMエントリのノードに到るRAM "96/3" ORAMI>HUO1-KASTV715 スセトてづて、合体のこ。るをセベエモをくごいれえ助 ♪xsm6 境回スサセて大量や丁全の一リツMARるする 従忠5は、CANエントリ"96/3"をルート(1001)

81

うじインエの用業計いなの本実おUインエMA Aの B E (4号38)である。また、図9中の各ノート33,34, Uイイエの"4/86" スセトてイて、対点話の土8M ようとしている。"99/8"のRAMエントリのCA "99/8"のRAMエントリ(ノード32)を、削除し スセトてリア、おる暗気引き路路、アいおりり図。るあ た即路アいて31更及斜峭のリインエMA A るよご B 路放 【0101】 (RAMエントリの削除) 次に、経路表作 。るす器獅を占さいなえ路

あり、各ノード32.36,37のRAMエントリは、実

よるもプリインエMA A るを有き本

、よりる密気引き路器、丁のるすよソート千多(Uイン) は、ノード34の他にノード37("112/4"のエ 3 6 オーし、るを照巻を3 6 オーしるを当時コオーし 胰の381−~、おる暗魚引表路路、コ次〔8010〕 があする。 リンカしているので、CAMエントリ38も削除可能と

判断する。また、ノード35は、CAMエントリ38と

よ、ノード35("96/4" のエントリリを削いまして、お

子/ードは/ード34のみであるので、経路表作成部5

○○ と オート 。 る を 競 き る る と オート 3 5 の

【0104】次に、経路表作成部5は、ノード34の親

は、ノード34("96/5"のエントリ)も削除可能と

る路気引表路路、ブのるむでその8 8 イーしおイーして ノードに相当するノード34を参照する。ノード34の

Bの881一人、おる暗気部を指数・コ次【8010】

トド33を参照する。ノード33の子ノードはノード3

/の "3/39" る专ど貼コパー/原の28パー/ だ

「0102」最初に、経路表件成部5は、ノード32に

このみであるので、経路表作成部5は、ノード33

3 電気引表路野、コ次。&を臨勤をよごいながドー\千 05

あする。

するためには、咳るRAMエントリ(ノード)がCANエ 行実がる暗気計奏路路を野吸網値式し揺上【7010】 。 ふれち斜哨ないイベエM する。このようにして、不要なRAMエントリ及びCA

断したノード32~35及びCAMエントリ38を削除

はしまします。 経路表情成部5は、削除可能と判

はち科別の予が辞費の心否かるいてれるでくしょしょく

08 計基路路, コ水。るべて見か"8/8/9" リインエMA CAMエントリをCAM6Bから探す。この例では、C るCANエントリ"96/5" より短いプレフィクスの でよるよし 御修しようと 神路表作成部5は、削除しようとす

重関コミよるれる天社コ 9 密索勢スソドてアノムスソド ててで本水るをお扶口"N" スクトワンとはスソリアと でホ水のこ , 計書両 , おJ合品ないアパち解酔J 7 M A 月11週位入41月で下で本次でを力技、さ四【3600】 関ムスソリアて 心木水る も 本状 、多 " N" スセト C V 下

ち帆砕い021(てーデセントモーハア遺外式れらり)と重 01 関744 "N" スペトてイン 落当 ムスソイス て ぐ ホ 次の こ 、おコ合即いないフパち宝鵄コ024(アーデゼントモー 小なスソイケてぐホ水るをあ枝、きろのこ。るれらりた

**☆野政の318~ぐそん~38~ぐそん式し話土ア** いてコスセトていてのめ式と成り受される暗野吸いにす ロてゼントモーバ、おる部気計表習録、CQ気へACとで モスや野処、」るも下鉢や野処垢土。るれち送海へ入し **ドストッカ水はイッセハ、J野班多スノドストッホ水る** 合脚式パち代入コミ耕敷やくトモーパがイセヤパるする 未成者"N" スセトヒリア、ファよコホコ【8 6 0 0】 ゚をは

ず、CAMエントリの削除処理について説明する。 は、強制的に何れかのCAMエントリを削除する。以 コ合製式J以下ないインエの(A 8 M A D お叉) 8 M A つ、アいも1)野政帝更の021(アーデザントデール、対 【0007】 〈CAMエントリの削除〉経路差作成部5

°د

掛多xsmδ 境回入サセて大量が境現の一! VMA A S店土 カえ渡さペリーしるいフパされているノードから教えた **- 小猫当で且、きでなることができ、且つ当該他** MAO式し替界をスセトマリといましたCAM トリ(例えば、削除対象のCAMエントリに保持された スエMAOの砂なーリツMAAるする点域多スソリてM るCAMエントリのCAMアドレスで指し示されるRA するさよし斜峭、おご合張るすが鳴いはあずしてて オ はならない。このため、経路表作成部5は、或るCAM 30 判断する。 れけなれち路部ならこいなが敵支ご突めのスクトワンと 場合には、CAMエントリが削除された後に実施される 【0098】CAM6のエントリが強制的に削除される

品する。 路表化成部513、以下の手順により削除可能なことを確 のCAMエントリを削除すると仮定する。この場合、経 "るへるも" 私え内, 体る密気計奏路路, ひき丁ノ激活 は、"96/3"及び"96/5"のCAMエントリを 理の例を示す図である。図8に示すように、CAM6B [0099] 図8は、強制的なCANエントリの削除処 40 。各世語勘を占これなえ

ていることを要する。このため、各ノードのRAMエントリには、CAMエントリとのリンクの有無を示すビットが用意され、CAMエントリとのリンクがある場合には、"0"と"1"との一方が設定され、リンクがない場合には、"0"と"1"との他方が設定される。

【0108】経路表作成部5は、上記削除処理において、削除か否かの判断の対象となっているRAMエントリに設定されたピットを参照し、リンクが設定されていることを示すピットを有するRAMエントリを削除する場合には、当該RAMエントリにリンクされているCA 10 Mエントリも削除する。

【0109】第1実施形態によると、ルーティングテープル20がCAM6とRAM7とを有し、プレフィクスがCAM6とRAM7とに跨って格納される。このため、RAMツリーのみを用いたルーティングに比べてルーティングに要する時間を短縮することができる。また、CAM6とRAM7とを併用することで、CAM6飲みを用いる場合に比べて多くのプレフィクス(のエントリ)をルーティングテーブル20に格納することができる。

【0110】さらに、経路表作成部5が、CAM6の利用率ητ、RAMの利用率ητ、差分δ、最大アクセス回数δmax、RAMツリー1回のアクセス時間ττ、パケットのルーティングの最大許容時間Tmaxを用いて新規のプレフィクスの登録処理(ルーティングテーブル20の更新処理)を行う。これによって、プレフィクスを最適な状態でルーティングテーブル20に格納することができる。このため、CAM6のオーパーフローを防止しつつ、RAMへのアクセス回数(RAMツリー17の段数)を可能な限り減らすことでルーティングの高速化を図る30ことができる。

【0111】このため、高速且つ大容量のルーティング テープルを構成することができる。

【0112】〈第2実施形態〉次に、本発明の第2実施形態を説明する。第2実施形態は、第1実施形態と共通点を有するので、相違点についてのみ説明する。第2実施形態は、本発明によるパケットの宛先情報管理装置を、パーチャル・プライベート・ネットワーク(VPN: Virtual Private Network)を構成するエッジルータに適用したものである。

【0113】 VPNは、インターネット上で仮想的な私 設ネットワークをつくる技術である。図10は、VPN の例を示す図である。図10に示すように、ISP(Internet Service Provider)のネットワーク51中に、各 ユーザ(ここでは企業Aおよび企業B)が専用に利用できるVPN52, 53が提供される。

【0114】企業Aの各サイト(端末装置)から送出されたパケットは、企業AのVPN52を通じてA社のみに伝わり、企業B等の他社に漏れない。また、企業AのVPN52には、企業B等の他社からのパケットも適わる

まない。企業BのVPN53についてもVPN52と同様である。このような仮想的な専用線を、ISPのネットワーク51の中にいくつも共存させ、設備を共用することによって安価な接続を提供する。

【0115】通常、企業Aと企業Bの利用するアドレスは独立に決められるので、同じアドレスが使われる可能性がある。そのため、各エッジルータ54.55は、VPN52又はVPN53にパケットを転送する場合には、どの企業網のパケットかを示すVPN-idと呼ばれる識別子を、IPアドレスと共にパケットに付加する。

【0116】各エッジルータ54,55の構成は、図1に示したルータ1とほぼ同じ構成を有しているので説明を省略する。図11は、各エッジルータ54,55のルーティング機構3(図1参照)に設けられたルーティングテーブル20Bの例を示す図である。

【0117】図11に示すように、CAM6Dには、VPN-idとプレフィクスとの組み合わせで構成される 拡張プレフィクスのエントリが格納されている。拡張プ 20 レフィクスは、VPN-idをなすビット列とプレフィ クスをなすビット列とが直列に連結された連続するビット列である。

【0118】図11では、説明のため、"VPN-id:プレフィクス"を、"0:A","1:B","2:C"と表記しているが、実際には、可変長のピット列である。この例では、VPN-id=1は、企業AのVPN-idであり、VPN-id=2は、企業BのVPN-idである。さらに、VPN-id=0は、公衆インターネット用の識別子としての特殊なVPN識別子であり、VPNを使用せずにISPのネットワーク51を利用する者に対して割り当てられている。

【0119】以上の点を除き、CAM6D及びRAMツリー17Dの構成、経路作成部5による処理、アドレス検索部9によるルーティング処理は、第1実施形態と同じであるので説明を省略する。

【0120】第2実施形態によれば、CAM6Dのコンテンツとして、IPアドレスの他にVPN識別子(VPN-id)が追加された拡張プレフィクスが用いられ、VPNを意識することなくCAMエントリ及びRAMツリーが構成されている。これにより、CAM6Dへのアクセスの追加及びRAM7のデータ追加なしに、VPN毎にルーティング検索を分離することができる。

【0121】また、特別なVPN識別子(例えば、VPN-id=0)を公衆インターネット用の識別子とすることで、VPN及び非VPNのトラフィックを同じルーティングテーブル20Bで検索することができる。

【0122】〔付記〕本発明は、以下のように特定することができる。

伝わり、企業B等の他社に漏れない。また、企業AのV (付記1)パケットの経路を選択するためのパケットの PN52には、企業B等の他社からのパケットも流れ込 50 宛先情報を管理する装置であって、第1メモリと、前記 第1メモリよりも情報の検索速度が遅く且つ集積度が高い第2メモリと、前記宛先情報が前記第1メモリと前記 第2メモリとに跨がる状態で格納された経路表を作成す る作成部と、を備えたパケットの宛先情報管理装置。

(付記2) 前記第1メモリの使用率の閾値を記憶した閾値記憶部をさらに備え、前記作成部は、前記第1メモリの使用率を取得し、取得した使用率が前記閾値記憶部に記憶された閾値未満である場合には、前記経路表に格納すべき宛先情報を前記第1メモリのみに格納する、付記1記載のパケットの宛先情報管理装置。

(付記3) 前記経路表に格納された宛先情報に対応する 出力ルートの情報を得る場合の最大許容時間を記憶した 許容時間記憶部をさらに備え、前記作成部は、前記最大 許容時間内で前記経路表から前記パケットの宛先情報が 検索され、検索された宛先情報に対応する出力ルートの 情報が取得されるように、前記宛先情報を前記第1メモ リと前記第2メモリとに跨がる状態で格納する、付記1 又は2記載のパケットの宛先情報管理装置。

(付記4)前記最大許容時間内で可能な前記第2メモリへの最大アクセス回数を記憶したアクセス回数記憶部を 20 さらに備え、前記作成部は、前記経路表に格納された宛先情報の検索に必要な前記第2メモリへのアクセス回数が前記最大アクセス回数以上となる場合には、前記アクセス回数が前記最大アクセス回数未満となるように、前記第2メモリに格納された、又は格納される予定の宛先情報を前記第1メモリに格納する付記3記載のパケットの宛先情報管理装置。

(付記5) 前記宛先情報は、所定長のビット列で構成され、前記作成部は、前記ピット列の最上位ビットから所定ピットまでを前記第1メモリに格納し、前記所定ピットから最下位ピットまでを前記第2メモリに格納する、付記1記載のパケットの宛先情報管理装置。

(付記6) 前記宛先情報は、パケットの宛先 I Pネットワークアドレスである、付記1記載のパケットの宛先情報管理装置。

(付記7) 前記宛先情報は、バーチャル・プライベート・ネットワークの識別子と、パケットの宛先 I Pネットワークアドレスとの組み合わせである、付記 1 記載のパケットの宛先情報管理装置。

(付記8) 前記作成部は、前記識別子を前記第1メモリ 40 のみに格納する、付記7記載のパケットの宛先情報管理 装置。

(付記9)パケットの宛先情報が第1メモリとこの第1 のメモリよりも情報の検索速度が遅く且つ集積度が高い 第2メモリとに跨る状態で格納された経路表と、入力さ れたパケットに対応する宛先情報を前記経路表から検索 し、検索した宛先情報に対応する出力ルートの情報を取 得する検索部と、を備えたパケットの経路選択装置。

(付記10) パケットの経路を選択するためのパケット の宛先情報を管理装置によって管理する方法であって、 前記管理装置は、前記宛先情報が第1メモリとこの第1 メモリよりも情報の検索速度が遅く且つ集積度が高い第 2メモリとに跨がる状態で格納された経路表を作成す る、ことを含むパケットの宛先情報管理方法。

(付記11) 前記管理装置は、前記第1メモリの使用率の関値を記憶し、記憶された前記第1メモリの使用率を取得し、取得した使用率が前記関値記憶部に記憶された関値未満である場合には、前記経路表に格納すべき宛先情報を前記第1メモリのみに格納する、付記10記載の10 パケットの宛先情報管理方法。

(付記12)前記管理装置は、前記経路表に格納された 宛先情報に対応する出力ルートの情報を得る場合の最大 許容時間を記憶し、前記最大許容時間内で前記経路表か ら前記パケットの宛先情報を検索し、検索した宛先情報 に対応する出力ルートの情報が取得されるように、前記 宛先情報を前記第1メモリと前記第2メモリとに跨がる 状態で格納する、付記10又は11記載のパケットの宛 先情報管理方法。

(付記13)前記管理装置は、前記最大許容時間内で可能な前記第2メモリへの最大アクセス回数を記憶し、前記経路表に格納された宛先情報の検索に必要な前記第2メモリへのアクセス回数が前記最大アクセス回数以上となる場合には、前記アクセス回数が前記最大アクセス回数未満となるように、前記第2メモリに格納された、又は格納される予定の宛先情報を前記第1メモリに格納する付記12記載のパケットの宛先情報管理方法。

(付記14) 前記宛先情報は、所定長のビット列で構成され、前記管理装置は、前記ビット列の最上位ビットから所定ビットまでを前記第1メモリに格納し、前記所定ビットから最下位ビットまでを前記第2メモリに格納する、付記10記載のパケットの宛先情報管理方法。

(付記15) 前記宛先情報は、パケットの宛先IPネットワークアドレスである、付記10記載のパケットの宛 先情報管理方法。

(付記16) 前記宛先情報は、バーチャル・プライベート・ネットワークの識別子と、パケットの宛先 I Pネットワークアドレスとの組み合わせである、付記10記載のパケットの宛先情報管理方法。

(付記17) 前記管理装置は、前記識別子を前記第1メモリのみに格納する、付記16記載のパケットの宛先情報管理方法。

(付記18) パケットの経路選択装置によってパケットの経路を選択する方法であって、前記経路選択装置は、パケットの宛先情報が第1メモリとこの第1のメモリよりも情報の検索速度が遅く且つ集積度が高い第2メモリとに跨る状態で格納された経路表を作成し、入力されたパケットに対応する宛先情報を前記経路表から検索し、検索した宛先情報に対応する出力ルートの情報を取得する、ことを含むパケットの経路選択方法。

[0123]

【発明の効果】本発明によれば、CAM方式で作成されたルーティングテーブルよりも多くのプレフィクスを保持することができ、且つRAMツリー方式で作成されたルーティングテーブルよりも高速にプレフィクスを検索することができる。

## 【図面の簡単な説明】

- 【図1】ルータの構成図
- 【図2】CAMの構成図
- 【図3】ノード(エントリ)の追加処理の説明図
- 【図4】ルーティングテーブルの説明図
- 【図5】プレフィクス追加の処理を示すフローチャート
- 【図6】プレフィクス追加の処理を示すフローチャート
- 【図7】 RAMツリーの段数を減らす処理の説明図
- 【図8】 CAMエントリ削除の例を示す図
- 【図9】RAMエントリ削除の例を示す図
- 【図10】 VPNの説明図
- 【図11】ルーティングテーブルの説明図
- 【図12】従来技術の説明図

- 【図13】従来技術の説明図 【図14】従来技術の説明図
- 【符号の説明】
- 1 ルータ
- 2 インターフェイスカード
- 3 ルーティング機構
- 4 ルーティングプロトコル処理部
- 5 ルート計算・経路表作成部
- 6 CAM
- 10 7 RAM
  - 8 ヘッダ抽出部
  - 9 アドレス検索部
  - 10 転送処理部
  - 12 データアレイ/マスクアレイ
  - 13 プライオリティ・エンコーダ -
  - 14 補助RAM
  - 17 RAMツリー
  - 20 ルーティングテーブル

【図1】







【図図】

[図4]



[図6] (図7)



[図9]

[図8]



[図10]



【図11】

[図12]



[図13]



【図14】



フロントページの続き

F 夕一ム(参考) 5K030 GA01 GA06 HA08 HB29 HD03 HD09 KA01 KA05 KA13 LB05 LE03 MA13